package com.itheima.dao;

import com.github.pagehelper.Page;
import com.itheima.pojo.Role;

import java.util.Map;
import java.util.Set;

public interface RoleDao {
    /**
     * 根据用户的id查询此用户包含的所有角色信息(其中角色只是基本信息)
     * @param userId
     * @return
     */
    Set<Role> findByUserId(Integer userId);
    /**
     * 根据角色名分页查询角色
     * @param queryString
     * @return
     */
    Page<Role> findByCondition(String queryString);

    /**
     * 添加角色
     * @param role
     */
    void addRole(Role role);

    /**
     * 添加角色和权限关系
     * @param map
     */
    void addRoleAndPermission(Map<String, Integer> map);

    /**
     * 编辑角色，返回原角色信息
     * @param id
     * @return
     */
    Role findRole(Integer id);

    /**
     * 修改角色信息
     * @param role
     */
    void update(Role role);

    /**
     * 删除角色与权限关联表
     * @param roleId
     */
    void delRoleAndPermission(Integer roleId);

    /**
     * 删除角色
     * @param id
     */
    void delRole(Integer id);

    /**
     * 查询所有角色信息
     * @return
     */
    Set<Role> findAll();

}
